//定制请求的实例

//导入axios  npm install axios
import axios, { AxiosResponse } from 'axios';
import { message } from 'ant-design-vue'
//定义返回值类型
export interface Result<T = any> {
    code: number;
    msg: string;
    data: T;
}
//定义一个变量,记录公共的前缀  ,  baseURL
//const baseURL = 'http://localhost:8080';
// const baseURL = '/api2';
const baseURL = 'http://8.138.173.253:9090';
const instance = axios.create({ baseURL })

import { useTokenStore } from '@/store/token.ts';
//添加请求拦截器
instance.interceptors.request.use(
    (config) => {
        //请求前的回调
        //添加token
        const tokenStore = useTokenStore();
        //判断有无token
        if (tokenStore.token) {
            config.headers.Authorization = tokenStore.token
        }
        return config;
    },
    (err) => {
        //请求错误的回调
        Promise.reject(err)
    }
)

// import {useRouter} from 'vue-router'
// const router=useRouter();
import router from '@/router'
//添加响应拦截器
instance.interceptors.response.use(
    (result: AxiosResponse) => {
        //判断业务状态码
        if (result.data.code === 200) {
            return result.data;
        }

        // //操作失败
        // alert(result.data.msg?result.data.msg:'服务异常')
        message.error(result.data.msg ? result.data.msg : '服务异常');
        //异步操作的状态转化为失败
        return Promise.reject(result.data);

    },
    (error) => {
        error.data = {};
        if (error && error.response) {
            switch (error.response.status) {
                case 400:
                    error.data.msg = '错误请求';
                    message.error(error.data.msg)
                    break
                case 401:
                    error.data.msg = '未授权，请重新登录';
                    message.error(error.data.msg)
                    break
                case 403:
                    error.data.msg = '拒绝访问';
                    message.error(error.data.msg)
                    break
                case 404:
                    error.data.msg = '请求错误,未找到该资源';
                    message.error(error.data.msg)
                    break
                case 405:
                    error.data.msg = '请求方法未允许';
                    message.error(error.data.msg)
                    break
                case 408:
                    error.data.msg = '请求超时';
                    message.error(error.data.msg)
                    break
                case 500:
                    error.data.msg = '服务器端出错';
                    message.error(error.data.msg)
                    break
                case 501:
                    error.data.msg = '网络未实现';
                    message.error(error.data.msg)
                    break
                case 502:
                    error.data.msg = '网络错误';
                    message.error(error.data.msg)
                    break
                case 503:
                    error.data.msg = '服务不可用';
                    message.error(error.data.msg)
                    break
                case 504:
                    error.data.msg = '网络超时';
                    message.error(error.data.msg)
                    break
                case 505:
                    error.data.msg = 'http版本不支持该请求';
                    message.error(error.data.msg)
                    break
                default:
                    error.data.msg = `连接错误${error.response.status}`;
                    message.error(error.data.msg)
            }
        } else {
            message.error("服务异常")
        }

        return Promise.reject(error);//异步的状态转化成失败的状态
    }
)

export default instance;

